/* Copyright (C) 2007 Hong Zhiqian */
/**
   @file profile_tm.h
   @author Hong Zhiqian
   @brief Various compatibility routines for Speex (TriMedia version)
*/
/*
   Redistribution and use in source and binary forms, with or without
   modification, are permitted provided that the following conditions
   are met:

   - Redistributions of source code must retain the above copyright
   notice, this list of conditions and the following disclaimer.

   - Redistributions in binary form must reproduce the above copyright
   notice, this list of conditions and the following disclaimer in the
   documentation and/or other materials provided with the distribution.

   - Neither the name of the Xiph.org Foundation nor the names of its
   contributors may be used to endorse or promote products derived from
   this software without specific prior written permission.

   THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
   ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
   LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
   A PARTICULAR PURPOSE ARE DISCLAIMED.  IN NO EVENT SHALL THE FOUNDATION OR
   CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
   EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
   PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
   PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF
   LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
   NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
   SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
*/
/**
*	@remarks	This file provide some capabilities to measure clock cycles.
*				Use this if unable to compile with TriMedia profile options
*/

extern int __profile_begin;
extern int __profile_end;

#if TM_PROFILE
#define	PROFILE_START()												\
		{															\
			__profile_begin = cycles();								\
		}															\

#define PROFILE_STOP()												\
		{															\
			__profile_end = cycles();								\
			printf("%s\t%d\n", __FUNCTION__, end - begin);			\
		}															\

#else
#define PROFILE_START()
#define PROFILE_STOP()
#endif

#if TM_PROFILE_SPXAUTOCORR
#define	_SPX_AUTOCORR_START()	PROFILE_START()
#define _SPX_AUTOCORR_STOP()	PROFILE_STOP()
#else
#define _SPX_AUTOCORR_START()
#define	_SPX_AUTOCORR_STOP()
#endif

#if TM_PROFILE_INNERPROD
#define	INNERPROD_START()	PROFILE_START()
#define INNERPROD_STOP()	PROFILE_STOP()
#else
#define INNERPROD_START()
#define	INNERPROD_STOP()
#endif

#if TM_PROFILE_PITCHXCORR
#define	PITCHXCORR_START()	PROFILE_START()
#define PITCHXCORR_STOP()	PROFILE_STOP()
#else
#define PITCHXCORR_START()
#define	PITCHXCORR_STOP()
#endif

#if TM_PROFILE_COMPUTEPITCHERROR
#define COMPUTEPITCHERROR_START()	PROFILE_START()
#define COMPUTEPITCHERROR_STOP()	PROFILE_STOP()
#else
#define COMPUTEPITCHERROR_START()
#define COMPUTEPITCHERROR_STOP()
#endif

#if TM_PROFILE_PITCHGAINSEARCH3TAPVQ
#define PITCHGAINSEARCH3TAPVQ_START()	PROFILE_START()
#define PITCHGAINSEARCH3TAPVQ_STOP()	PROFILE_STOP()
#else
#define PITCHGAINSEARCH3TAPVQ_START()
#define PITCHGAINSEARCH3TAPVQ_STOP()
#endif

#if TM_PROFILE_OPENLOOPNBESTPITCH
#define OPENLOOPNBESTPITCH_START()	PROFILE_START()
#define OPENLOOPNBESTPITCH_STOP()	PROFILE_STOP()
#else
#define OPENLOOPNBESTPITCH_START()
#define OPENLOOPNBESTPITCH_STOP()
#endif


#if TM_PROFILE_LSP_INTERPOLATE
#define	LSPINTERPOLATE_START()	PROFILE_START()
#define LSPINTERPOLATE_STOP()	PROFILE_STOP()
#else
#define LSPINTERPOLATE_START()
#define	LSPINTERPOLATE_STOP()
#endif

#if TM_PROFILE_CHEBPOLYEVA
#define	CHEBPOLYEVA_START()	PROFILE_START()
#define CHEBPOLYEVA_STOP()	PROFILE_STOP()
#else
#define CHEBPOLYEVA_START()
#define	CHEBPOLYEVA_STOP()
#endif


#if TM_PROFILE_COMPUTEQUANTWEIGHTS
#define	COMPUTEQUANTWEIGHTS_START()	PROFILE_START()
#define COMPUTEQUANTWEIGHTS_STOP()	PROFILE_STOP()
#else
#define COMPUTEQUANTWEIGHTS_START()
#define	COMPUTEQUANTWEIGHTS_STOP()
#endif

#if TM_PROFILE_LSPQUANT
#define	LSPQUANT_START()	PROFILE_START()
#define LSPQUANT_STOP()		PROFILE_STOP()
#else
#define LSPQUANT_START()
#define	LSPQUANT_STOP()
#endif

#if TM_PROFILE_LSPWEIGHTQUANT
#define	LSPWEIGHTQUANT_START()		PROFILE_START()
#define LSPWEIGHTQUANT_STOP()		PROFILE_STOP()
#else
#define LSPWEIGHTQUANT_START()
#define	LSPWEIGHTQUANT_STOP()
#endif

#if TM_PROFILE_FIRMEM16
#define	FIRMEM16_START()	PROFILE_START()
#define FIRMEM16_STOP()		PROFILE_STOP()
#else
#define FIRMEM16_START()
#define	FIRMEM16_STOP()
#endif

#if TM_PROFILE_IIRMEM16
#define	IIRMEM16_START()	PROFILE_START()
#define IIRMEM16_STOP()		PROFILE_STOP()
#else
#define IIRMEM16_START()
#define	IIRMEM16_STOP()
#endif

#if TM_PROFILE_FILTERMEM16
#define	FILTERMEM16_START()		PROFILE_START()
#define FILTERMEM16_STOP()		PROFILE_STOP()
#else
#define FILTERMEM16_START()
#define	FILTERMEM16_STOP()
#endif

#if TM_PROFILE_COMPUTERMS16
#define	COMPUTERMS16_START()	PROFILE_START()
#define COMPUTERMS16_STOP()		PROFILE_STOP()
#else
#define COMPUTERMS16_START()
#define	COMPUTERMS16_STOP()
#endif

#if TM_PROFILE_NORMALIZE16
#define	NORMALIZE16_START()		PROFILE_START()
#define NORMALIZE16_STOP()		PROFILE_STOP()
#else
#define NORMALIZE16_START()
#define	NORMALIZE16_STOP()
#endif

#if TM_PROFILE_BWLPC
#define	BWLPC_START()		PROFILE_START()
#define BWLPC_STOP()		PROFILE_STOP()
#else
#define BWLPC_START()
#define BWLPC_STOP()
#endif

#if TM_PROFILE_HIGHPASS
#define	HIGHPASS_START()	PROFILE_START()
#define HIGHPASS_STOP()		PROFILE_STOP()
#else
#define HIGHPASS_START()
#define HIGHPASS_STOP()
#endif

#if TM_PROFILE_SIGNALMUL
#define	SIGNALMUL_START()		PROFILE_START()
#define SIGNALMUL_STOP()		PROFILE_STOP()
#else
#define SIGNALMUL_START()
#define SIGNALMUL_STOP()
#endif

#if TM_PROFILE_SIGNALDIV
#define	SIGNALDIV_START()		PROFILE_START()
#define SIGNALDIV_STOP()		PROFILE_STOP()
#else
#define SIGNALDIV_START()
#define SIGNALDIV_STOP()
#endif

#if TM_PROFILE_COMPUTEIMPULSERESPONSE
#define	COMPUTEIMPULSERESPONSE_START()		PROFILE_START()
#define COMPUTEIMPULSERESPONSE_STOP()		PROFILE_STOP()
#else
#define COMPUTEIMPULSERESPONSE_START()
#define COMPUTEIMPULSERESPONSE_STOP()
#endif

#if TM_PROFILE_COMPUTEWEIGHTEDCODEBOOK
#define	COMPUTEWEIGHTEDCODEBOOK_START()			PROFILE_START()
#define COMPUTEWEIGHTEDCODEBOOK_STOP()			PROFILE_STOP()
#else
#define COMPUTEWEIGHTEDCODEBOOK_START()
#define	COMPUTEWEIGHTEDCODEBOOK_STOP()
#endif

#if TM_PROFILE_TARGETUPDATE
#define	TARGETUPDATE_START()			PROFILE_START()
#define TARGETUPDATE_STOP()				PROFILE_STOP()
#else
#define TARGETUPDATE_START()
#define	TARGETUPDATE_STOP()
#endif


#if TM_PROFILE_VQNBEST
#define	VQNBEST_START()		PROFILE_START()
#define VQNBEST_STOP()		PROFILE_STOP()
#else
#define VQNBEST_START()
#define	VQNBEST_STOP()
#endif

#if TM_PROFILE_VQNBESTSIGN
#define	VQNBESTSIGN_START()		PROFILE_START()
#define VQNBESTSIGN_STOP()		PROFILE_STOP()
#else
#define VQNBESTSIGN_START()
#define	VQNBESTSIGN_STOP()
#endif

#if TM_PROFILE_PREPROCESSANALYSIS
#define	PREPROCESSANAYLSIS_START()		PROFILE_START()
#define PREPROCESSANAYLSIS_STOP()		PROFILE_STOP()
#else
#define PREPROCESSANAYLSIS_START()
#define	PREPROCESSANAYLSIS_STOP()
#endif

#if TM_PROFILE_UPDATENOISEPROB
#define	UPDATENOISEPROB_START()		PROFILE_START()
#define UPDATENOISEPROB_STOP()		PROFILE_STOP()
#else
#define UPDATENOISEPROB_START()
#define	UPDATENOISEPROB_STOP()
#endif

#if TM_PROFILE_COMPUTEGAINFLOOR
#define	COMPUTEGAINFLOOR_START()	PROFILE_START()
#define COMPUTEGAINFLOOR_STOP()		PROFILE_STOP()
#else
#define COMPUTEGAINFLOOR_START()
#define	COMPUTEGAINFLOOR_STOP()
#endif

#if TM_PROFILE_FILTERDCNOTCH16
#define FILTERDCNOTCH16_START()		PROFILE_START()
#define FILTERDCNOTCH16_STOP()		PROFILE_STOP()
#else
#define FILTERDCNOTCH16_START()
#define	FILTERDCNOTCH16_STOP()
#endif

#if TM_PROFILE_MDFINNERPROD
#define MDFINNERPROD_START()		PROFILE_START()
#define MDFINNERPROD_STOP()			PROFILE_STOP()
#else
#define MDFINNERPROD_START()
#define	MDFINNERPROD_STOP()
#endif

#if TM_PROFILE_SPECTRALMULACCUM
#define SPECTRALMULACCUM_START()		PROFILE_START()
#define SPECTRALMULACCUM_STOP()			PROFILE_STOP()
#else
#define SPECTRALMULACCUM_START()
#define	SPECTRALMULACCUM_STOP()
#endif

#if TM_PROFILE_WEIGHTEDSPECTRALMULCONJ
#define WEIGHTEDSPECTRALMULCONJ_START()		PROFILE_START()
#define WEIGHTEDSPECTRALMULCONJ_STOP()		PROFILE_STOP()
#else
#define WEIGHTEDSPECTRALMULCONJ_START()
#define	WEIGHTEDSPECTRALMULCONJ_STOP()
#endif

#if TM_PROFILE_MDFADJUSTPROP
#define MDFADJUSTPROP_START()		PROFILE_START()
#define MDFADJUSTPROP_STOP()		PROFILE_STOP()
#else
#define MDFADJUSTPROP_START()
#define	MDFADJUSTPROP_STOP()
#endif

#if TM_PROFILE_SPEEXECHOGETRESIDUAL
#define SPEEXECHOGETRESIDUAL_START()	PROFILE_START()
#define SPEEXECHOGETRESIDUAL_STOP()		PROFILE_STOP()
#else
#define SPEEXECHOGETRESIDUAL_START()
#define	SPEEXECHOGETRESIDUAL_STOP()
#endif

#if TM_PROFILE_LSPENFORCEMARGIN
#define LSPENFORCEMARGIN_START()	PROFILE_START()
#define LSPENFORCEMARGIN_STOP()		PROFILE_STOP()
#else
#define LSPENFORCEMARGIN_START()
#define	LSPENFORCEMARGIN_STOP()
#endif

#if TM_PROFILE_LSPTOLPC
#define LSPTOLPC_START()	PROFILE_START()
#define LSPTOLPC_STOP()		PROFILE_STOP()
#else
#define LSPTOLPC_START()
#define	LSPTOLPC_STOP()
#endif

#if TM_PROFILE_MAXIMIZERANGE
#define MAXIMIZERANGE_START()	PROFILE_START()
#define MAXIMIZERANGE_STOP()	PROFILE_STOP()
#else
#define MAXIMIZERANGE_START()
#define	MAXIMIZERANGE_STOP()
#endif

#if TM_PROFILE_RENORMRANGE
#define RENORMRANGE_START()	PROFILE_START()
#define RENORMRANGE_STOP()	PROFILE_STOP()
#else
#define RENORMRANGE_START()
#define	RENORMRANGE_STOP()
#endif

#if TM_PROFILE_POWERSPECTRUM
#define POWERSPECTRUM_START()	PROFILE_START()
#define POWERSPECTRUM_STOP()	PROFILE_STOP()
#else
#define POWERSPECTRUM_START()
#define	POWERSPECTRUM_STOP()
#endif

#if TM_PROFILE_QMFSYNTH
#define QMFSYNTH_START()	PROFILE_START()
#define QMFSYNTH_STOP()		PROFILE_STOP()
#else
#define QMFSYNTH_START()
#define	QMFSYNTH_STOP()
#endif

#if TM_PROFILE_QMFDECOMP
#define QMFDECOMP_START()	PROFILE_START()
#define QMFDECOMP_STOP()	PROFILE_STOP()
#else
#define QMFDECOMP_START()
#define	QMFDECOMP_STOP()
#endif

#if TM_PROFILE_FILTERBANKCOMPUTEBANK32
#define FILTERBANKCOMPUTEBANK32_START()	PROFILE_START()
#define FILTERBANKCOMPUTEBANK32_STOP()	PROFILE_STOP()
#else
#define FILTERBANKCOMPUTEBANK32_START()
#define	FILTERBANKCOMPUTEBANK32_STOP()
#endif

#if TM_PROFILE_FILTERBANKCOMPUTEPSD16
#define FILTERBANKCOMPUTEPSD16_START()	PROFILE_START()
#define FILTERBANKCOMPUTEPSD16_STOP()	PROFILE_STOP()
#else
#define FILTERBANKCOMPUTEPSD16_START()
#define	FILTERBANKCOMPUTEPSD16_STOP()
#endif


